<template>
  <div v-loading="loading" class="dashboard-container">
    <div class="app-container">
      <!-- 工具栏 -->
      <page-tools :show-before="true">
        <!-- 前面内容 -->
        <template v-slot:before>当前审批中 0 本月审批通过 1 本月审批驳回 0</template>
        <template>
          <el-button
            size="mini"
            type="primary"
            @click="$router.push('/approvals/securitySetting')"
          >流程设置</el-button>
        </template>
      </page-tools>
      <!-- <ApprovalPageTool /> -->
      <el-card class="hr-block">
        <el-table
          :data="list"
          style="width: 100%"
          :default-sort="{prop: 'date', order: 'descending'}"
        >
          <el-table-column type="selection" width="30" />
          <el-table-column type="index" width="80" label="序号" />
          <el-table-column prop="processName" label="审批类型" sortable />
          <el-table-column prop="username" label="申请人" sortable />
          <el-table-column prop="procCurrNodeUserName" label="当前审批人" sortable />
          <el-table-column label="审批发起时间" sortable>
            <template>
              <span>{{ new Date().toLocaleString() }}</span>
            </template>
          </el-table-column>
          <el-table-column prop="process_state" label="审批状态" sortable>
            <template v-slot="{ row }">
              <span v-if="row.processState === 0" class="rovalsState">
                <em class="sub" />已提交
              </span>
              <span v-if="row.processState === 1" class="rovalsState">
                <em class="stay" />审批中
              </span>
              <span v-if="row.processState === 2" class="rovalsState">
                <em class="adopt" />审批通过
              </span>
              <span v-if="row.processState === 3" class="rovalsState">
                <em class="reject" />审批不通过
              </span>
              <span v-if="row.processState === 4" class="rovalsState">
                <em class="revoke" />撤销
              </span>
            </template>
          </el-table-column>
          <el-table-column label="操作" width="100">
            <template>
              <!-- <el-button type="text" size="mini" @click="toDetail(row)">查看</el-button> -->
              <el-button type="text" size="mini">查看</el-button>
            </template>
          </el-table-column>
        </el-table>
        <!-- 分页组件 -->
        <el-row type="flex" align="middle" justify="center" style="height: 60px">
          <el-pagination
            :total="page.total"
            :page-size="page.pagesize"
            layout="prev, pager, next"
            @current-change="changePage"
          />
        </el-row>
      </el-card>
    </div>
  </div>
</template>

<script>
import { getApprovalList } from '@/api/approval'
// import ApprovalPageTool from './components/approval-tool'
import pageTools from './components/page-tools.vue'
export default {
  name: 'SocialTableIndex',
  components: { pageTools },
  data() {
    return {
      list: [],
      loading: false,
      page: {
        page: 1,
        total: 0,
        pageSize: 10
      }
    }
  },
  created() {
    this.getApprovalList()
  },
  methods: {
    // 初始化数据
    async getApprovalList() {
      this.loading = true
      const { rows, total } = await getApprovalList({
        year: 2018,
        ...this.page
      })
      this.page.total = total
      this.list = rows
      this.loading = false
    },
    toDetail(row) {
      var name = row.processName
      console.log(row.processName)
      switch (name) {
        case '工资':
          this.$router.push('/approvals/salaryApproval/' + row.processId)
          break
        case '入职':
          this.$router.push({
            path: '/approvals/enterApproval/' + row.processId
          })
          break
        case '请假':
          this.$router.push('/approvals/leaveApproval/' + row.processId)
          break
        case '离职':
          this.$router.push({
            path: '/approvals/quitApproval/' + row.processId
          })
          break
        case '加班':
          this.$router.push({
            path: '/approvals/overtimeApproval/' + row.processId
          })
      }
    },

    changePage(newPage) {
      this.page.newPage = newPage
      this.getApprovalList()
    }
  }
}
</script>

